perm filename TEST.SAI[X,AIL] blob
sn#165904 filedate 1973-12-09 generic text, type T, neo UTF8
COMMENT ⊗ VALID 00015 PAGES
RECORD PAGE DESCRIPTION
00001 00001
00005 00002 Sail Tester
00006 00003 Item Consistency Check
00007 00004 Allocator Test, Comment in Funny Places Test.
00008 00005 Forward Procedure Checks
00010 00006 Binary Operation Tests
00012 00007 Start_Code Opcode Test
00013 00008 Inchwl Test.
00015 00009 String-Creation Test
00020 00010 Constant Procedures Test
00022 00011 Scan Test
00026 00012 Fullword Test
00030 00013 Real String Conversion Test, Preload Test
00034 00014 Constant Boolean Expression Test
00036 00015 Random Simple Things Tests.
00038 ENDMK
⊗;
COMMENT Sail Tester;
BEGIN "TEST"
COMMENT This program is a comprehensive test of new features added to
SAIL since February, 1972.
The first section includes features added or modified as of 2-7-72;
DEFINE CRLF="('15&'12)";
EXTERNAL INTEGER _SKIP_;
BOOLEAN PROCEDURE WANT(STRING TEST);
BEGIN OUTSTR(TEST&"? ");
RETURN(INCHWL="Y");
END "WANT";
COMMENT Item Consistency Check
Be sure that item numbers start at the same place, with or with
declared items. First try it with ITEM IT as a declaration, then
without. IT should have the value 11. The NEW should be 11 if IT
is not declared, else 12;
COMMENT ITEM IT; REQUIRE 3 NEW_ITEMS; COMMENT IT SHOULD BE NUMBER 11;
IF WANT("ITEMVAR TEST") THEN BEGIN "ITEMVARS"
ITEMVAR X;
X←NEW; COMMENT THIS SHOULD BE NUMBER 12 -- 11 IF ITEM DECL REMOVED;
OUTSTR(CVS(CVN(X)) & CRLF);
END "ITEMVARS";
COMMENT Allocator Test, Comment in Funny Places Test.
Make sure that double-pp request and smaller-than-default
String-pp request work ok.
Also (5-12-72) make sure that Comments after declared names
don't foul up the declarations;
REQUIRE 125 SYSTEM_PDL, 300 SYSTEM_PDL, 30 STRING_PDL;
BEGIN
INTEGER IXI COMMENT IF THINGS ARE BROKEN, "COMMENT" WILL BE DEFINED;;
PROCEDURE XXX; IXI←3;
COMMENT IF THINGS ARE BROKEN, THIS COMMENT WILL BE BROKEN;
END;
COMMENT Forward Procedure Checks
This test made entirely at compile time. The following procedures have
errors:
P2 -- FORWARD has too few formals
P3 -- FORWARD has too many formals
P4 -- FORWARD has too few formals
P5 -- FORWARD has too many formals
P6 -- FORWARD and actual have different names, but types match, OK.
P7 -- Type mismatch
P8 -- No FORWARD, no error -- all OK
Enable this test by Truifying the IFC;
IFC FALSE THENC
BEGIN "FORWARDS"
FORWARD PROCEDURE P1;
PROCEDURE P1;;
FORWARD PROCEDURE P2;
PROCEDURE P2(INTEGER X);;
FORWARD PROCEDURE P3(INTEGER X);
PROCEDURE P3;;
FORWARD PROCEDURE P4(INTEGER X);
PROCEDURE P4(INTEGER X,Y);;
FORWARD PROCEDURE P5(INTEGER X,Y);
PROCEDURE P5(INTEGER X);;
FORWARD PROCEDURE P6(INTEGER X);
PROCEDURE P6(INTEGER Z);;
FORWARD PROCEDURE P7(INTEGER X);
PROCEDURE P7(REAL X);;
PROCEDURE P8(INTEGER X;STRING Y);;
END "FORWARDS";
ENDC
COMMENT Binary Operation Tests
This test was designed specifically to test binary operations which
have two STTEMPs as operands. However, it is mildly useful
to check other binary operations as well. Just watch the
flashing lights.
;
IF WANT("BINARY TEST") THEN BEGIN "BINARY OPS"
DEFINE BTEST(OP,RES)="
IF (OP)≠RES THEN OUTSTR(""BINARY OPERATION `OP' YIELDS ""&
CVS(I)&"", SHOULD BE RES""&CRLF)";
INTEGER I,J; STRING S,T;
J←5;
BTEST(I←2-3,-1);
BTEST(I←J-3,2);
BTEST(I←I-3,-1);
I←2;
BTEST(I←I↑J,32);
S←"EFG"; T←"ABCD";
BTEST(I←S-T,4);
S←3&4&5&6&7; I←2;
T←7&6&5&4&3;
BTEST(I←I↑S,8);
BTEST(I←S[3 FOR 1]+I,13);
BTEST(I←S[3 FOR 1]↑T[4 FOR 1],625);
BTEST(I←IF I>J THEN 3 ELSE 4,3);
BTEST(I←IF S[3 FOR 1]>T[4 FOR 1] THEN 3 ELSE 4,3);
END "BINARY OPS";
COMMENT Start_Code Opcode Test
All opcodes are now available in START_CODE.
CALL is the first opcode, and has the value 40.
INTUUO is the last, with value 723.
MOVE is in the middle, with value 200.
Correct compilation of these instructions does not guarantee
correctness of all opcodes, but it does eliminate systematic error.
This code will not be executed -- just examine it;
IF FALSE THEN START_CODE "OPCODES"
CALL 1,1; COMMENT TEST FIRST OPCODE;
COMMENT INTUUO 1,1; COMMENT TEST LAST OPCODE;
MOVE 1,1; COMMENT TEST SOMETHING IN THE MIDDLE;
END "OPCODES";
COMMENT Inchwl Test.
INCHWL now stops on ANY activation character, returning that
character in _SKIP_, not in the string. It sucks up
the LF after a CR, returning the CR.
This test will tell you if it doesn't like you;
IF WANT("INCHWL TEST") THEN BEGIN "INCHWL"
STRING S;
OUTSTR("TYPE ""THIS IS A LINE"", TERMINATE WITH <CR>"&CRLF);
IF ¬EQU("THIS IS A LINE",S←INCHWL)
THEN OUTSTR("STRING RESULT WRONG"&CRLF);
IF _SKIP_≠'15 THEN OUTSTR("BREAK CHAR WRONG"&CRLF);
OUTSTR("TYPE ""THIS Hhβ A LINE"", TERMINATE WITH <LF>"&CRLF);
IF ¬EQU("THIS IS A LINE",S←INCHWL)
THEN OUTSTR("STRING RESULT WRONG"&CRLF);
IF _SKIP_≠'12 THEN OUTSTR("BREAK CHAR WRONG"&CRLF);
OUTSTR("TYPE ""THIS IS A LINE"", TERMINATE WITH <ALT>"&CRLF);
IF ¬EQU("THIS IS A LINE",S←INCHWL)
THEN OUTSTR("STRING RESULT WRONG"&CRLF);
IF _SKIP_≠'175 THEN OUTSTR("BREAK CHAR WRONG"&CRLF);
OUTSTR("TYPE ""THIS IS A LINE"", TERMINATE WITH <CTRL-D>"&CRLF);
IF ¬EQU("THIS IS A LINE",S←INCHWL)
THEN OUTSTR("STRING RESULT WRONG"&CRLF);
IF _SKIP_≠'304 THEN OUTSTR("BREAK CHAR WRONG"&CRLF)
END "INCHWL";
COMMENT String-Creation Test
This just runs CAT and friends through their paces. It was designed
to test the new optimized CAT, CATCHR, CHRCAT, CHRCHR, and to
make sure that the removal of TOPSTR didn't blow the other
string-making routines. Sometimes help is requested from the TTY.
A new test (5-12-72) assures that if SGLIGN(USER) is on, strings are
aligned on full-word boundaries after concatenation, even if
optimization must be removed. ;
IF WANT("STRING TEST") THEN BEGIN "STRING CREATION"
INTEGER I,J; STRING S,T; EXTERNAL INTEGER SGLIGN;
BOOLEAN PROCEDURE UNALIGNED(REFERENCE STRING S);
BEGIN INTEGER I;
START_CODE MOVE 1,S; LSH 1,-30; MOVEM 1,I END;
RETURN(IF 1≠I≠'44 THEN TRUE ELSE FALSE);
END "UNALIGNED";
S←NULL;
T←"ABC";
IF ¬EQU(S←T&"CDE","ABCCDE") THEN
OUTSTR("CAT WITH TWO COPIES DOESN'T WORK");
IF ¬EQU(S&"CDE"&CVS(32456),"ABCCDECDE32456") THEN
OUTSTR("CAT WITH ONE COPY, OR WITH NO COPY DOESN'T WORK"&CRLF);
I←"G";
IF ¬EQU(T&I,"ABCG") THEN OUTSTR("CATCHR DOESN'T WORK"&CRLF);
IF ¬EQU(I&T,"GABC") THEN OUTSTR("CHRCAT DOESN'T WORK"&CRLF);
IF ¬EQU(I&I,"GG") THEN OUTSTR("CHRCHR DOESN'T WORK"&CRLF);
FOR J←1 STEP 1 UNTIL 20 DO BEGIN
T←S;
S←NULL;
FOR I←1 STEP 1 UNTIL 200 DO S←S&" "&CVS(I); COMMENT JUST APPEND;
END;
IF ¬EQU(S,T) THEN OUTSTR("STRNGC MESSED UP CAT"&CRLF);
USERCON(SGLIGN,I←-1,1);
S←"ABCDE"; S←S&"FGHIJ"; T←S[3 FOR 8];
T←T&CVS(25);
BEGIN "SGLIGN TEST" I←0 END;
IF UNALIGNED(S) THEN OUTSTR("SGLIGN DIDN'T WORK AT ALL"&CRLF);
IF UNALIGNED(T) THEN
OUTSTR("SGLIGN DIDN'T WORK IF ALREADY CATTED"&CRLF);
S←"ABCDE"; S←S&"FGHIJ"; T←S[3 FOR 8]; T←T&"ABCDE";
IF UNALIGNED(T) THEN
OUTSTR("SGLIGN DIDN'T WORK IF ARG1 ON TOP"&CRLF);
USERCON(SGLIGN,I←0,1);
SETBREAK(1,"ABCDE",NULL,"I");
S←"THIS IS A LINE";
T←SCAN(S,1,I);
IF ¬EQU(T,"THIS IS ")∨¬EQU(S," LINE") THEN
OUTSTR("SCAN DOESN'T WORK"&CRLF);
IF INTSCAN(S←"12345ABCDE",J)≠12345 THEN
OUTSTR("INTSCAN DOESN'T WORK"&CRLF);
IF ¬(1.1@-4≤REALSCAN(S←"1.23@-4ABCDE",J)≤1.3@-4) THEN
OUTSTR("REALSCAN DOESN'T WORK"&CRLF);
IF ¬EQU(CVSTR(CVASC("ABCDE")),"ABCDE") THEN
OUTSTR("CVSTR OR CVASC DOESN'T WORK"&CRLF);
IF ¬EQU(CVXSTR(CVSIX("ABCDEF")),"ABCDEF") THEN
OUTSTR("CVXSTR OR CVSIX DOESN'T WORK"&CRLF);
OPEN(1,"TTY",0,2,0,100,I,I);
OUTSTR("TYPE ""THIS IS A LINE""<CRLF>"&CRLF);
SETBREAK(1,10,13,"I");
S←INPUT(1,1);
IF ¬EQU("THIS IS A LINE",S)∨I≠'12 THEN
OUTSTR("INPUT DOESN'T WORK"&CRLF);
OUTSTR("TYPE ""12345 1.23@-4""<CRLF>"&CRLF);
IF INTIN(1)≠12345 THEN
OUTSTR("INTIN DOESN'T WORK"&CRLF);
IF ¬(1.1@-4≤REALIN(1)≤1.3@-4) THEN
OUTSTR("REALIN DOESN'T WORK"&CRLF);
RELEASE(1);
END "STRING CREATION";
COMMENT Constant Procedures Test
This test assures that CAT, SUBSTR, CVS, CVOS, ... CVD, CVO, EQU
will happen correctly at compile time. Part of it assures that
procedures with wrong numbers of arguments will not be evaluated.;
IF WANT("CONSTANT PROCEDURES TEST") THEN BEGIN "CONST PROC"
INTEGER I; STRING ST;
IFC ¬EQU("ABC"&"DEF","ABCDEF") THENC
OUTSTR("CONSTANT CAT DOESN'T WORK"&CRLF); ENDC
IFC ¬EQU("ABC"&CRLF,"ABC
") THENC OUTSTR("CONSTANT CAT DOESN'T WORK"&CRLF); ENDC
IFC ¬EQU(("ABCDE")[2 TO 4D") THENC
OUTSTR("CONSTANT SUBSTR DOESN'T WORK"&CRLF); ENDC
SETFORMAT(0,0);
IF ¬EQU(CVS(25),"25") THEN OUTSTR("CONSTANT CVS DOESN'T WORK"&CRLF);
SETFORMAT(10,5);
IFC TRUE THENC
BEGIN "CVG TEST" I←0 END;
IF ¬EQU(CVG(-3.5),"-3.500000 ") THEN
OUTSTR("CONSTANT CVG DOESN'T WORK"&CRLF);
ENDC
IFC CVD("12345")≠12345 THENC
OUTSTR("CONSTANT CVD DOESN'T WORK"&CRLF); ENDC
IFC FALSE THENC COMMENT WE'LL DO OUR BEST, BUT ... ;
I←EQU("ABC");
I←EQU("ABC","CDE","EFG");
I←CVD;
I←CVD("ABC","DEF");
ST←CVS;
ST←CVS(2,3,4);
ENDC
END "CONST PROC";
COMMENT Scan Test
This was designed to test SCAN in all its many guises.
It will tell you what it doesn't like;
IF WANT("SCAN TEST") THEN BEGIN "SCAN TEST"
PROCEDURE OUTSTR(STRING S);
BEGIN "OUTSTR"
EXTERNAL PROCEDURE OUTSTR(STRING S);
OUTSTR(S&CRLF)
END "OUTSTR";
STRING S,T; INTEGER I;
SETBREAK(1,"ABCD",NULL,"I");
SETBREAK(2,"ABCD"," ","I");
SETBREAK(3,"ABCD",NULL,"IA");
SETBREAK(4,"ABCD",NULL,"IR");
S←NULL;
IF ¬EQU(T←SCAN(S,1,I),NULL)∨¬EQU(S,NULL)∨I≠0 THEN
OUTSTR("SCAN 1 DOESN'T WORK");
S←"A LINE IS THIS";
IF ¬EQU(T←SCAN(S,1,I),NULL)∨¬EQU(S," LINE IS THIS")∨I≠"A"
THEN OUTSTR("SCAN 2 DOESN'T WORK");
S←"THIS IS A LINE";
IF ¬EQU(T←SCAN(S,1,I),"THIS IS ") ∨¬EQU(S," LINE")∨I≠"A"
THEN OUTSTR("SCAN 3 DOESN'T WORK");
S←"THIS LINE IS A";
IF ¬EQU(T←SCAN(S,1,I),"THIS LINE IS ")∨¬EQU(S,NULL)∨I≠"A"
THEN OUTSTR("SCAN 4 DOESN'T WORK");
S←"THIS IS LINE";
IF ¬EQU(T←SCAN(S,1,I),"THIS IS LINE")∨¬EQU(S,NULL)∨I≠0
THEN OUTSTR("SCAN 5 DOESN'T WORK");
S←"A LINE IS THIS";
IF ¬EQU(T←SCAN(S,2,I),NULL)∨¬EQU(S," LINE IS THIS")∨I≠"A"
THEN OUTSTR("SCAN 6 DOESN'T WORK");
S←"THIS IS A LINE";
IF ¬EQU(T←SCAN(S,2,I),"THISIS") ∨¬EQU(S," LINE")∨I≠"A"
THEN OUTSTR("SCAN 7 DOESN'T WORK");
S←"THIS LINE IS A";
IF ¬EQU(T←SCAN(S,2,I),"THISLINEIS")∨¬EQU(S,NULL)∨I≠"A"
THEN OUTSTR("SCAN 8 DOESN'T WORK");
S←"THIS IS LINE";
IF ¬EQU(T←SCAN(S,2,I),"THISISLINE")∨¬EQU(S,NULL)∨I≠0
THEN OUTSTR("SCAN 9 DOESN'T WORK");
S←"A LINE IS THIS";
IF ¬EQU(T←SCAN(S,3,I),"A")∨¬EQU(S," LINE IS THIS")∨I≠"A"
THEN OUTSTR("SCAN 10 DOESN'T WORK");
S←"THIS IS A LINE";
IF ¬EQU(T←SCAN(S,3,I),"THIS IS A") ∨¬EQU(S," LINE")∨I≠"A"
THEN OUTSTR("SCAN 11 DOESN'T WORK");
S←"THIS LINE IS A";
IF ¬EQU(T←SCAN(S,3,I),"THIS LINE IS A")∨¬EQU(S,NULL)∨I≠"A"
THEN OUTSTR("SCAN 12 DOESN'T WORK");
S←"THIS IS LINE";
IF ¬EQU(T←SCAN(S,3,I),"THIS IS LINE")∨¬EQU(S,NULL)∨I≠0
THEN OUTSTR("SCAN 13 DOESN'T WORK");
S←"A LINE IS THIS";
IF ¬EQU(T←SCAN(S,4,I),NULL)∨¬EQU(S,"A LINE IS THIS")∨I≠"A"
THEN OUTSTR("SCAN 14 DOESN'T WORK");
S←"THIS IS A LINE";
IF ¬EQU(T←SCAN(S,4,I),"THIS IS ") ∨¬EQU(S,"A LINE")∨I≠"A"
THEN OUTSTR("SCAN 15 DOESN'T WORK");
S←"THIS LINE IS A";
IF ¬EQU(T←SCAN(S,4,I),"THIS LINE IS ")∨¬EQU(S,"A")∨I≠"A"
THEN OUTSTR("SCAN 16 DOESN'T WORK");
S←"THIS IS LINE";
IF ¬EQU(T←SCAN(S,4,I),"THIS IS LINE")∨¬EQU(S,NULL)∨I≠0
THEN OUTSTR("SCAN 17 DOESN'T WORK");
END "SCAN TEST";
COMMENT Fullword Test
This tests WORDIN, WORDOUT, ARRYIN, ARROUT in many ways. It
complains if it doesn't like you;
IF WANT("FULLWORD IO TEST") THEN BEGIN "FULLWORD TRANSFERS"
INTEGER EOF,I,J;
INTEGER ARRAY X[0:383];
PROCEDURE CHECKB(INTEGER FLAG);
BEGIN "CHECKB"
INTEGER L,H;
I←POINT(36,X[0],35);
IF FLAG THEN L←LDB(I-1) ELSE IF
L≠LDB(I-1) THEN OUTSTR("LOWER BOUND CLOBBERED IN FULLWORD"&CRLF);
IF FLAG THEN H←LDB(I+384) ELSE IF
H≠LDB(I+384) THEN OUTSTR("UPPER BOUND CLOBBERED IN FULLWORD"&CRLF);
END "CHECKB";
CHECKB(TRUE);
OPEN(1,"DSK",'10,0,2,0,I,EOF);
ENTER(1,"TEST.DAT",I);
FOR I←0 STEP 1 UNTIL 383 DO X[I]←I;
BEGIN "WR FILE" END "WR FILE";
ARRYOUT(1,X[0],128); "ONE RECORD"
ARRYOUT(1,X[I←128],29); "WITHIN A RECORD"
ARRYOUT(1,X[I←I+29],113); "ACROSS A RECORD BOUNDARY"
WORDOUT(1,X[I←I+113]); "A SINGLE WORD"
ARRYOUT(1,X[I←I+1],113); "LAST GROUP, 3 RECORDS TOTAL"
RELEASE(1);
CHECKB(FALSE); "MAKE SURE NOTHING HAS MOVED"
X[0]←-1; ARRBLT(X[1],X[0],383);
OPEN(1,"DSK",'10,2,0,0,I,EOF);
LOOKUP(1,"TEST.DAT",I);
BEGIN "RD FILE" END "RD FILE";
ARRYIN(1,X[0],113); "READ WITHIN RECORD"
X[I←113]←WORDIN(1); "ONE WORD, SAME RECORD"
ARRYIN(1,X[I←I+1],28); "ACROSS BOUNDARY"
ARRYIN(1,X[I←I+28],114); "FINISH UP THE RECORD"
ARRYIN(1,X[I←I+114],129); "READ ONE PAST EOF"
BEGIN "EOF CHK" END "EOF CHK";
IF ¬EOF THEN OUTSTR("EOF DOESN'T WORK IN WORDIN"&CRLF) ELSE
IF EOF≠('20010 LSH 18)+128 THEN OUTSTR("EOF WITH BAD VALUE"&CRLF);
RELEASE(1);
CHECKB(FALSE);
FOR I←0 STEP 1 UNTIL 383 DO IF X[I]≠I THEN
OUTSTR("WORD "&CVS(I)&" HAS VALUE "&CVS(X[I])&CRLF);
OPEN(1,"DSK",'17,0,0,0,I,EOF);
ENTER(1,"TEST.DAT",I);
FOR I←1 STEP 1 UNTIL 10 DO WORDOUT(1,I);
RELEASE(1);
OPEN(1,"DSK",'17,0,0,0,I,I);
LOOKUP(1,"TEST.DAT",I);
BEGIN "DMP RD TEST" END "DMP RD TEST";
FOR J←1 STEP 1 UNTIL 10 DO IF (I←WORDIN(1))≠J THEN
OUTSTR("DUMP MODE: WORD "&CVS(J)&" HAS VALUE "&CVS(I)&CRLF);
RELEASE(1)
END "FULLWORD TRANSFERS";
COMMENT Real String Conversion Test, Preload Test
This tests CVE, CVF, CVG. I test so much because once I modified
the spacing algorithm, and now that I put it back I don't
trust it;
IF WANT("REALSTRING TEST") THEN BEGIN "REALSTRING CONVERSIONS"
STRING S,COD; REAL X;INTEGER I;
SETFORMAT(0,0);
X←3.5;
IF ¬EQU(CVE(X)," @0 ") THEN OUTSTR("CVE 1 IS WRONG"&CRLF);
IF ¬EQU(CVF(X)," 4.") THEN OUTSTR("CVF 2 IS WRONG"&CRLF);
IF ¬EQU(CVG(X)," @0 ") THEN OUTSTR("CVG 3 IS WRONG"&CRLF);
SETFORMAT(10,5);
IF ¬EQU(CVE(X)," .35000@1 ") THEN OUTSTR("CVE 4 IS WRONG"&CRLF);
IF ¬EQU(CVF(X)," 3.50000") THEN OUTSTR("CVF 5 IS WRONG"&CRLF);
IF ¬EQU(CVG(X)," 3.5000 ") THEN OUTSTR("CVG 6 IS WRONG"&CRLF);
SETFORMAT(-1,0);
IF ¬EQU(CVE(X)," @0 ") THEN OUTSTR("CVE 7 IS WRONG"&CRLF);
IF ¬EQU(CVF(X)," 4.") THEN OUTSTR("CVF 8 IS WRONG"&CRLF);
IF ¬EQU(CVG(X)," @0 ") THEN OUTSTR("CVG 9 IS WRONG"&CRLF);
SETFORMAT(-10,5);
IF ¬EQU(CVE(X)," .35000@1 ") THEN OUTSTR("CVE 10 IS WRONG"&CRLF);
IF ¬EQU(CVF(X)," 003.50000") THEN OUTSTR("CVF 11 IS WRONG"&CRLF);
IF ¬EQU(CVG(X)," 3.5000 ") THEN OUTSTR("CVG 12 IS WRONG"&CRLF);
X←-3.5;SETFORMAT(0,0);
IF ¬EQU(CVE(X),"- @0 ") THEN OUTSTR("CVE 13 IS WRONG"&CRLF);
IF ¬EQU(CVF(X),"-4.") THEN OUTSTR("CVF 14 IS WRONG"&CRLF);
IF ¬EQU(CVG(X),"- @0 ") THEN OUTSTR("CVG 15 IS WRONG"&CRLF);
SETFORMAT(10,5);
IF ¬EQU(CVE(X),"-.35000@1 ") THEN OUTSTR("CVE 16 IS WRONG"&CRLF);
IF ¬EQU(CVF(X)," -3.50000") THEN OUTSTR("CVF 17 IS WRONG"&CRLF);
IF ¬EQU(CVG(X),"-3.5000 ") THEN OUTSTR("CVG 18 IS WRONG"&CRLF);
SETFORMAT(-1,0);
IF ¬EQU(CVE(X),"- @0 ") THEN OUTSTR("CVE 19 IS WRONG"&CRLF);
IF ¬EQU(CVF(X),"-4.") THEN OUTSTR("CVF 20 IS WRONG"&CRLF);
IF ¬EQU(CVG(X),"- @0 ") THEN OUTSTR("CVG 21 IS WRONG"&CRLF);
SETFORMAT(-10,5);
IF ¬EQU(CVE(X),"-.35000@1 ") THEN OUTSTR("CVE 22 IS WRONG"&CRLF);
IF ¬EQU(CVF(X),"-003.50000") THEN OUTSTR("CVF 23 IS WRONG"&CRLF);
IF ¬EQU(CVG(X),"-3.5000 ") THEN OUTSTR("CVG 24 IS WRONG"&CRLF);
END "REALSTRING CONVERSIONS";
IFC TRUE THENC
IF FALSE THEN BEGIN "PRELOAD WARNINGS"
DEFINE PRELOAD_WITH="COMMENT";
INTEGER N;
PRELOAD_WITH 0,0,0,0,0;
INTEGER ARRAY FOO[1:N];
PRELOAD_WITH 1,2,3,45;
EXTERNAL INTEGER ARRAY BAZ[1:N];
FOO[1]←3
END "PRELOAD WARNINGS";
ENDC
COMMENT Constant Boolean Expression Test
Enable and look at the code if you suspect something;
IFC FALSE THENC
BEGIN "BOOL"
INTEGER A,B;
IF A THEN B←3;
IF 3 THEN B←3;
IF A<B THEN B←3;
IF A<3 THEN B←3;
IF 3<A THEN B←3;
IF 3<5 THEN B←3;
IF 3>5 THEN B←3;
IF A∧B THEN B←3;
IF A∧(3<5) THEN B←3;
IF A∧(5<3) THEN B←3;
IF 5<3∧A THEN B←3;
IF A∧3 THEN B←3;
IF 3<5∧4<7 THEN B←3;
IF 3<5∧4>7 THEN B←3;
IF 3>5∧4<7 THEN B←3;
IF 3>5∧4>7 THEN B←3;
IF A∨B THEN B←3;
IF A∨(3<5) THEN B←3;
IF A∨(5<3) THEN B←3;
IF 5<3∨A THEN B←3;
IF A∨3 THEN B←3;
IF 3<5∨4<7 THEN B←3;
IF 3<5∨4>7 THEN B←3;
IF 3>5∨4<7 THEN B←3;
IF 3>5∨4>7 THEN B←3;
A←3<5∧(4>7∨2<3);
A←IF 3<5∧(4>7∨2<3) THEN 2 ELSE 3;
A←3<5∧(4>7∨2>3);
A←IF 3<5∧(4>7∨2>3) THEN 2 ELSE 3;
END "BOOL"
ENDC
COMMENT Random Simple Things Tests.
These should take very little time, and should always work.
It's just a way to assure that trivial bugs don't creep back in;
BEGIN "RANDOM"
STRING SS;
INTEGER I,J, K;
Comment be sure that NEGAT bug in Loop code is gone;
SS←"ABCDE";
J←1; K←0;
FOR I←1 STEP 1 UNTIL 10-LENGTH(SS) DO K←-1;
IF I≠6∨¬K THEN OUTSTR("NEGAT BUG IN FOR CODE IS BACK"&CRLF);
J←1; K←0;
FOR I←1 STEP J UNTIL 10-LENGTH(SS) DO K←-1;
IF I≠6∨¬K THEN OUTSTR("NEGAT BUG IN FOR CODE IS BACK"&CRLF);
Comment type the version number. Load this with something whose
Version numbers don't exist, are the same, are not the same;
START_CODE MOVE 1,'137; MOVEM 1,I END;
OUTSTR("VERSION IS "&CVOS(I)&CRLF);
END "RANDOM"
END "TEST";